草庐IT

c++ - C++中static的含义

全部标签

c++ - C++ 标准中短语 "constructors do not have names"的含义

在尝试理解C++标准中的“构造函数没有名称”这一短语时,我似乎在clang中发现了一个错误。有人可以证实这一点吗?VS2015andgcc拒绝此代码,我认为他们它是是正确的。至少,这是我从N4140中的§12.1[class.ctor]/2得到的印象:#includeclassA{public:A(){std::cout§12.1[class.ctor]/2在N4140中:Aconstructorisusedtoinitializeobjectsofitsclasstype.Becauseconstructorsdonothavenames,theyareneverfounddurin

c++ - 什么时候应该在非成员函数之前写关键字 'static'?

我最近在SO上看到了一些关于函数前的static关键字的信息,我想知道如何正确使用它。1)什么时候应该在非成员函数前写关键字static?2)在header中定义静态非成员函数是否危险?为什么(不)?(附带问题)3)是否可以以某种方式在头文件中定义一个类,以便它只在您首先使用它的翻译单元中可用?(我问这个的原因是因为我正在学习STL,它可能是我的谓词等(可能是仿函数)的一个很好的解决方案,因为我不喜欢定义成员以外的函数-cpp文件中的函数)(另外,我认为它在某种程度上与原始问题相关,因为根据我目前的推理,它会在函数之前做与static相同的事情)编辑看到一些答案时提出的另一个问题:4)

c++ - 什么时候应该在非成员函数之前写关键字 'static'?

我最近在SO上看到了一些关于函数前的static关键字的信息,我想知道如何正确使用它。1)什么时候应该在非成员函数前写关键字static?2)在header中定义静态非成员函数是否危险?为什么(不)?(附带问题)3)是否可以以某种方式在头文件中定义一个类,以便它只在您首先使用它的翻译单元中可用?(我问这个的原因是因为我正在学习STL,它可能是我的谓词等(可能是仿函数)的一个很好的解决方案,因为我不喜欢定义成员以外的函数-cpp文件中的函数)(另外,我认为它在某种程度上与原始问题相关,因为根据我目前的推理,它会在函数之前做与static相同的事情)编辑看到一些答案时提出的另一个问题:4)

c++ - At 符号 (@) 和美元符号 ($) 在 C 或 C++ 中是否有任何特殊含义

最近我的一位friend在一次采访中遇到了这个问题。面试官问他$、@、|、^、~等特殊字符在c或c++中有没有用,在哪里。我知道|、^和~分别用作按位或、异或和补码。但是不知道@和$有没有什么特殊含义。如果可以,请举例说明它可以应用在哪里? 最佳答案 @在C中一般是无效的;它不用于任何事情。它被Objective-C用于各种目的,但那完全是另一回事。$也是无效的,但许多实现允许它出现在标识符中,就像字母一样。(例如,在这些实现中,如果您愿意,可以将变量或函数命名为$$$。)尽管如此,它也没有任何特殊含义。

c++ - At 符号 (@) 和美元符号 ($) 在 C 或 C++ 中是否有任何特殊含义

最近我的一位friend在一次采访中遇到了这个问题。面试官问他$、@、|、^、~等特殊字符在c或c++中有没有用,在哪里。我知道|、^和~分别用作按位或、异或和补码。但是不知道@和$有没有什么特殊含义。如果可以,请举例说明它可以应用在哪里? 最佳答案 @在C中一般是无效的;它不用于任何事情。它被Objective-C用于各种目的,但那完全是另一回事。$也是无效的,但许多实现允许它出现在标识符中,就像字母一样。(例如,在这些实现中,如果您愿意,可以将变量或函数命名为$$$。)尽管如此,它也没有任何特殊含义。

c++ - static const std::map<string, int> vs if-elseif

我编写了一个将字符串转换为数字的函数。我看到了两种可能的写法:intconvert(conststd::stringinput){if(input=="one"){return1;}elseif(input=="two"){return2;}//etc.return0;}或者intconvert(conststd::stringinput){staticconstmaptable={{"one",1},{"two",2}//etc.}constautoresult=table.find(input);if(result==table.end()){return0;}returnresu

c++ - static const std::map<string, int> vs if-elseif

我编写了一个将字符串转换为数字的函数。我看到了两种可能的写法:intconvert(conststd::stringinput){if(input=="one"){return1;}elseif(input=="two"){return2;}//etc.return0;}或者intconvert(conststd::stringinput){staticconstmaptable={{"one",1},{"two",2}//etc.}constautoresult=table.find(input);if(result==table.end()){return0;}returnresu

c++ - `static constexpr` 在常量表达式中调用的函数是...错误?

我有以下代码:classMyClass{staticconstexprboolfoo(){returntrue;}voidbar()noexcept(foo()){}};我希望因为foo()是一个staticconstexpr函数,并且由于它是在声明bar之前定义的,所以这将是完全可以接受。但是,g++给了我以下错误:error:‘staticconstexprboolMyClass::foo()’calledinaconstantexpression这...没什么用,因为在常量表达式中调用函数的能力是constexpr的全部要点。clang++更有帮助。除了指出noexcept的参数

c++ - `static constexpr` 在常量表达式中调用的函数是...错误?

我有以下代码:classMyClass{staticconstexprboolfoo(){returntrue;}voidbar()noexcept(foo()){}};我希望因为foo()是一个staticconstexpr函数,并且由于它是在声明bar之前定义的,所以这将是完全可以接受。但是,g++给了我以下错误:error:‘staticconstexprboolMyClass::foo()’calledinaconstantexpression这...没什么用,因为在常量表达式中调用函数的能力是constexpr的全部要点。clang++更有帮助。除了指出noexcept的参数

c++ - 为什么使用 std::forward<T> 而不是 static_cast<T&&>

当给出以下结构的代码时templatevoidfoo(Args&&...args){...}我经常看到库代码使用static_cast在用于参数转发的函数中。通常,这样做的理由是使用static_cast避免不必要的模板实例化。给定语言的引用折叠和模板推导规则。我们通过static_cast获得完美的转发,此声明的证明如下(在误差范围内,我希望答案能启发)当给定右值引用时(或为了完整性-没有像thisexample中的引用限定),这会折叠引用,结果是一个右值。使用的规则是&&&&->&&(规则1以上)当给定左值引用时,这会折叠引用以使结果是左值。这里使用的规则是&&&->&(规则2以上